watsonx Assistant Subordinate Bot
This section will describe how we were able to query one watsonx assistant from another using the watsonx assistant API. In addition, this guide will also include information about how to update session variables on the subordinate bot from the calling bot. There are two different ways to integrate with a subordinate watsonx assisant bot:
Assistant Custom Extension
Generate API Key
- Navigate to the subordinate bot instance
- In the sidebar, navigate to "Assistant Settings"
- Under "Assistant IDs and API details", select "Generate API key" and save it for later
Identify OpenAPI spec values
Two values will be needed to connect to a subordinate Assistant:
- service instance url
- environmentID
- Within the Assistant Builder's sidebar, navigate to the "Assistant Settings"
- Under "Assistant IDs and API details", select "View details"
- Save/copy the values for:
service instance URL
Draft/Live Environment ID
(whichever is applicable)
Create the Custom Extension
- Navigate and download the OpenAPI spec for another assistant bot here
- Modify the server url at line 10 with the
service instance url
from step 3 here - Navigate to the integrations section within the Assistant Builder sidebar
- Select "Build custom extension" and name the extension
- Upload the OpenApi spec from step 1 and press "Finish"
- Select "Add+" within the newly configured extension
- Select "Next" and update values:
- Authentication type: Basic auth
- Username: apikey
- Password: Password from here
Action Integration
Two api calls are needed to successfully integrate this extension:
Create a session id
- Within the appropriate action, create a step and under "And then" select "Use an extension"
- Select the appropriate subordinate bot extension made here
- Select the Operation as "Create Session"
- Set the Parameters to:
- environment_id: Environment ID from step 3 of Identify OpenAPI spec values
tipMake sure the "environment_id" variable type is 'text'
Make a dialog request
- Create a new step after the action with the "create a session" extension
- Under the "And then" Section, select "Use an extension"
- Select the appropriate subordinate bot extension made here
- Select the Operation as "Make dialog request"
- Set the Parameters to:
- input.text: input.text
- input.message_type: text
- useContext.skills.actions skill.skill_variables :
{"DEFINED_VARIABLE" : "VARIABLE_VALUE"}
- session_id: [session_id from previous step w/ "Create Session" call]
- environment_id: Environment ID from step 3 of Identify OpenAPI spec values
A note about session variables
Session variables are an important tool for storing information within and between watsonx assistant actions. They are defined either by the user or by the assistant, and each session has a unique instance of each session variable.
If you need to pass more information than just the input query to the subordinate bot, a session variable is the way to go. To do this, the session variable must already be defined on the subordinate side before its value can be updated by a dialog request. Once the variable is defined, it can be updated by including its name along with a new value in a json object under the useContext.skills.actions skill.skill_variables field.
watsonx Orchestrate Skill
This section will cover how the bot-bot communication OpenAPI spec was adapted for use by watsonx orchestrate. The example file can be found here. The setup instructions for the specification itself are the same as for the watsonx assistant spec.
Changes made
Of the significant changes made to the specification, there was one functional change and one more cosmetic change.
The functional change was to specify in the specification the session variable that will be changed by the watsonx orchestrate skill. For whatever reason, watsonx orchestrate cannot take arbitrary expressions such as a json object as inputs. As a workaround, the session variables must be explicity defined in the specification. Because I was feeling whimsical when I made this, the example session variable is named "jellybelly".
The other change was to give all of the inputs default values in order to be able to hide the input forms that would otherwise appear in the watsonx orchestrate chat. This will not, however, allow you to hide the forms when the skill is imported into watsonx assistant. Unfortunately, those forms cannot be hidden.
Another minor change is that the second step, sending the dialog request, is given an output format using the watsonx orchestrate tag "x-ibm-nl-output-template". This allows the user to forgo the very ugly table that shows up by default, although this can also be done through the watsonx orchestrate UI.
Setup
In order to build a skill flow from this OpenAPI specification, import the spec and setup the authorization in the same that you would for watsonx assistant. Then follow these steps:
- Click "Enhance this skill" for both skills in order to publish them.
- Click the dropdown next to "Add Skills" and select "Create a skill flow"
- Arrange the two skills you just imported into the skill flow, with the first skill being the "Create Session" skill and the second being "Make a dialog request w required"
- Complete the inputs for the two skills, and select "hide this form from the user" if you would like to not show the form when running the skill flow. make sure that the "input.message_type" is set to "text" for the second skill.